<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>封装简单动画函数</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        div{
            position: absolute;
            top: 100px;
            left: 0;
            width: 100px;
            height: 100px;
            background-color: #f00;
        }
        p{
            position: absolute;
            top: 300px;
            left: 0;
            width: 120px;
            height: 50px;
            background-color: aqua;
        }
    </style>
</head>
<body>
    <div></div>
    <p></p>
    <button>蓝色动</button>
    <script>
        //动画函数封装
        //el  需要执行动画的元素对象
        //target  动画目标坐标值
        function animation(el,target){   
            // var timer=setInterval(function(){
                //不论触发几次，只执行一次
                clearInterval(el.timer);
            // 3. 利用定时器不断重复这个操作
            el.timer=setInterval(function(){
                // 1. 获得盒子当前位置
                var x=el.offsetLeft;
                // 2. 让盒子在当前位置加上1个移动距离
                // 5. 注意此元素需要添加定位，才能使用element.style.left
                el.style.left=x+1+'px';

                // 4. 加一个结束定时器的条件
                if(el.offsetLeft==target){
                    clearInterval(el.timer);
                }
            },15)
        }
        var div=document.querySelector('div');
        var p=document.querySelector('p');
        var btn=document.querySelector('button')

        animation(div,400);
        btn.onclick=function(){
            animation(p,400)
        }
        // animation(p,600);
    </script>
</body>
</html>